Typescript 中的 Partial, Readonly, Record, Pick

您所在的位置:网站首页 js readonly关键字 Typescript 中的 Partial, Readonly, Record, Pick

Typescript 中的 Partial, Readonly, Record, Pick

2023-10-02 10:13| 来源: 网络整理| 查看: 265

在 typescript (后面简称为 ts)中定义 interface(后面简称为“接口”) 时,常常需要对进行二次封装或调整,而 ts 在2.1版本中加入了一些程序类型工具,供开发者方便的进行此类操作。

备注:这些程序类型仅限制用于 type 类型声明中。

可以先看看它们的源码定义:

/** * Make all properties in T optional */ type Partial = { [P in keyof T]?: T[P]; }; /** * Make all properties in T readonly */ type Readonly = { readonly [P in keyof T]: T[P]; }; /** * From T, pick a set of properties whose keys are in the union K */ type Pick = { [P in K]: T[P]; }; /** * Construct a type with a set of properties K of type T */ type Record = { [P in K]: T; };

这些程序类型早在2016年就发布了,因此已经被很多框架或插件所使用。那么来依次说明:

Record

以 typeof 格式快速创建一个类型,此类型包含一组指定的属性且都是必填。

type Coord = Record; // 等同于 type Coord = { x: number; y: number; }

具体的复杂业务场景中,一般会接口 Pick 、Partial 等组合使用,从而过滤和重组出新的类型定义。

Partial

将类型定义的所有属性都修改为可选。

type Coord = Partial; // 等同于 type Coord = { x?: number; y?: number; } Readonly

不管是从字面意思,还是定义上都很好理解:将所有属性定义为自读。

type Coord = Readonly; // 等同于 type Coord = { readonly x: number; readonly y: number; } // 如果进行了修改,则会报错: const c: Coord = { x: 1, y: 1 }; c.x = 2; // Error: Cannot assign to 'x' because it is a read-only property. Pick

从类型定义的属性中,选取指定一组属性,返回一个新的类型定义。

type Coord = Record; type CoordX = Pick; // 等用于 type CoordX = { x: number; }

官方预置的高级类型还有很多其他的,已经补上了:TypeScript 的所有 高级类型。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3